## **RISC-V Instruction Set**

## **Core Instruction Formats**

| 31                    | 27           | 26 | 25   | 24 | 20  | 19    | 15     | 14     | 12       | 11          | 7   | 6      | 0      |        |
|-----------------------|--------------|----|------|----|-----|-------|--------|--------|----------|-------------|-----|--------|--------|--------|
| funct7                |              |    |      | rs | 2   | 2 rs1 |        | funct3 |          |             | rd  | opo    | code   | R-type |
| imm[11:0              |              |    | 0] r |    | rs  | l     | funct3 |        | rd       |             | opo | code   | I-type |        |
|                       | imm[11:5]    |    | rs   | 2  | rs1 |       | fun    | ct3    | imm[4:0] |             | opo | code   | S-type |        |
| imr                   | imm[12 10:5] |    | 5]   | rs | 2   | rs1   |        | fun    | ct3      | imm[4:1 11] |     | opo    | code   | B-type |
|                       | imm[31:12]   |    |      |    |     |       |        |        |          | rd opcode   |     | U-type |        |        |
| imm[20 10:1 11 19:12] |              |    |      |    |     |       |        |        |          | rd          | ope | code   | J-type |        |

## **RV32I Base Integer Instructions**

| add<br>sub<br>xor<br>or | ADD<br>SUB              | R  |         |     |                |                              |              |
|-------------------------|-------------------------|----|---------|-----|----------------|------------------------------|--------------|
| xor                     | CLIB                    | 10 | 0110011 | 0x0 | 0x00           | rd = rs1 + rs2               |              |
|                         | 300                     | R  | 0110011 | 0x0 | 0x20           | rd = rs1 - rs2               |              |
| or                      | XOR                     | R  | 0110011 | 0x4 | 0x00           | $rd = rs1 ^ rs2$             |              |
|                         | OR                      | R  | 0110011 | 0x6 | 0x00           | rd = rs1   rs2               |              |
| and                     | AND                     | R  | 0110011 | 0x7 | 0x00           | rd = rs1 & rs2               |              |
| sll                     | Shift Left Logical      | R  | 0110011 | 0x1 | 0x00           | rd = rs1 << rs2              |              |
| srl                     | Shift Right Logical     | R  | 0110011 | 0x5 | 0x00           | rd = rs1 >> rs2              |              |
| sra                     | Shift Right Arith*      | R  | 0110011 | 0x5 | 0x20           | rd = rs1 >> rs2              | msb-extends  |
| slt                     | Set Less Than           | R  | 0110011 | 0x2 | 0x00           | rd = (rs1 < rs2)?1:0         |              |
| sltu                    | Set Less Than (U)       | R  | 0110011 | 0x3 | 0x00           | rd = (rs1 < rs2)?1:0         | zero-extends |
| addi                    | ADD Immediate           | I  | 0010011 | 0x0 |                | rd = rs1 + imm               |              |
| xori                    | XOR Immediate           | I  | 0010011 | 0x4 |                | rd = rs1 ^ imm               |              |
| ori                     | OR Immediate            | I  | 0010011 | 0x6 |                | rd = rs1   imm               |              |
| andi                    | AND Immediate           | I  | 0010011 | 0x7 |                | rd = rs1 & imm               |              |
| slli                    | Shift Left Logical Imm  | I  | 0010011 | 0x1 | imm[5:11]=0x00 | rd = rs1 << imm[0:4]         |              |
| srli                    | Shift Right Logical Imm | I  | 0010011 | 0x5 | imm[5:11]=0x00 | rd = rs1 >> imm[0:4]         |              |
| srai                    | Shift Right Arith Imm   | I  | 0010011 | 0x5 | imm[5:11]=0x20 | rd = rs1 >> imm[0:4]         | msb-extends  |
| slti                    | Set Less Than Imm       | I  | 0010011 | 0x2 |                | rd = (rs1 < imm)?1:0         |              |
| sltiu                   | Set Less Than Imm (U)   | I  | 0010011 | 0x3 |                | rd = (rs1 < imm)?1:0         | zero-extends |
| lb                      | Load Byte               | I  | 0000011 | 0x0 |                | rd = M[rs1+imm][0:7]         |              |
| 1h                      | Load Half               | I  | 0000011 | 0x1 |                | rd = M[rs1+imm][0:15]        |              |
| lw                      | Load Word               | I  | 0000011 | 0x2 |                | rd = M[rs1+imm][0:31]        |              |
| lbu                     | Load Byte (U)           | I  | 0000011 | 0x4 |                | rd = M[rs1+imm][0:7]         | zero-extends |
| lhu                     | Load Half (U)           | I  | 0000011 | 0x5 |                | rd = M[rs1+imm][0:15]        | zero-extends |
| sb                      | Store Byte              | S  | 0100011 | 0x0 |                | M[rs1+imm][0:7] = rs2[0:7]   |              |
| sh                      | Store Half              | S  | 0100011 | 0x1 |                | M[rs1+imm][0:15] = rs2[0:15] |              |
| SW                      | Store Word              | S  | 0100011 | 0x2 |                | M[rs1+imm][0:31] = rs2[0:31] |              |
| beq                     | Branch ==               | В  | 1100011 | 0x0 |                | if(rs1 == rs2) PC += imm     |              |
| bne                     | Branch !=               | В  | 1100011 | 0x1 |                | if(rs1 != rs2) PC += imm     |              |
| blt                     | Branch <                | В  | 1100011 | 0x4 |                | if(rs1 < rs2) PC += imm      |              |
| bge                     | Branch ≥                | В  | 1100011 | 0x5 |                | if(rs1 >= rs2) PC += imm     |              |
| bltu                    | Branch < (U)            | В  | 1100011 | 0x6 |                | if(rs1 < rs2) PC += imm      | zero-extends |
| bgeu                    | Branch $\geq$ (U)       | В  | 1100011 | 0x7 |                | if(rs1 >= rs2) PC += imm     | zero-extends |
| jal                     | Jump And Link           | J  | 1101111 |     |                | rd = PC+4; PC += imm         |              |
| jalr                    | Jump And Link Reg       | I  | 1100111 | 0x0 |                | rd = PC+4; PC = rs1 + imm    |              |
| lui                     | Load Upper Imm          | U  | 0110111 |     |                | rd = imm << 12               |              |

## **RV32M Multiply Extension**

| Inst  | Name             | FMT | Opcode  | funct3 | funct7 | Description (C)         |
|-------|------------------|-----|---------|--------|--------|-------------------------|
| mul   | MUL              | R   | 0110011 | 0x0    | 0x01   | rd = (rs1 * rs2)[31:0]  |
| mulh  | MUL High         | R   | 0110011 | 0x1    | 0x01   | rd = (rs1 * rs2)[63:32] |
| mulsu | MUL High (S) (U) | R   | 0110011 | 0x2    | 0x01   | rd = (rs1 * rs2)[63:32] |
| mulu  | MUL High (U)     | R   | 0110011 | 0x3    | 0x01   | rd = (rs1 * rs2)[63:32] |
| div   | DIV              | R   | 0110011 | 0x4    | 0x01   | rd = rs1 / rs2          |
| divu  | DIV (U)          | R   | 0110011 | 0x5    | 0x01   | rd = rs1 / rs2          |
| rem   | Remainder        | R   | 0110011 | 0x6    | 0x01   | rd = rs1 % rs2          |
| remu  | Remainder (U)    | R   | 0110011 | 0x7    | 0x01   | rd = rs1 % rs2          |